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(71) We, The Marconi Company 
Limited, a British Company, of Marconi 
House, New Street, Chelmsford, Essex, CM1 
1PL, do hereby declare the invention, for 
5 which we pray that a patent may be granted 
to us, and the method by which it is to be 
performed, to be particularly described in 
and by the following statement: — 
This invention relates to data processing 

10 systems and in particular to multi-processor 
data processing systems utilising a data-bus 
or highway in order to permit the processors 
in the system to communicate with each 
other and with memory stores within the 

15 system and with external devices. 

One example of such a system is the Locus 
16 data processing system. "Locus" is a 
Registered Trade Mark of the Marconi 
Company Limited. 

20 Usually at least one of the processors in the 
system is capable of general purpose arith- 
metic and logical operations using a program 
stored within the system. 
This invention provides a multi-processor 

25 data processing system comprising: a store 
having a plurality of locations each defined 
by an address; a plurality of processors each 
having a multi-bit address output and means 
for feeding at least some bits of this output to 

30 the store to provide a corresponding number 
of bits of an address input of the latter; data 
transfer means connected between the proc- 
essors and the store for the communication of 
data between a processor and an address in 

35 the store which address is dependent on the 
address output of the processor, access con- 
trol means for controlling access to the store 
by the processors in response to receipt of a 
code; a plurality of tables each containing 

40 codes; table selecting means for transmitting 
a processor identity signal indicating what 
processor is currently to access the store and 
for selecting a table associated with that 
processor; means for addressing the selected 

45 table with at least part of the address output 



of that processor which is currently to access 
the store whereby the table outputs a code; 
and means for feeding the code outputted by 
the selected table to the access control means 
thereby causing said access control means to 50 
control acces to the store in a manner defined 
by said code. 

In one form of the invention said multi-bit 
address output of each processor has A+B 
digits and means is provided for feeding the 55 
B digits to the store to provide a correspond- 
ing B digits of said address input of the store; 
the means for addressing a selected table is 
adapted to define a table address in depen- 
dence on the A digits; each code contained in 60 
the tables has Z digits; and said access 
control means is provided by a further Z 
digits of said address input of the store and 
by a connection for feeding the Z digits of the 
codes outputted by the tables of the corre- 65 
sponding Z digits of the store address 
whereby said codes limit access of the 
processors to particular locations in the store. 

In another form of the invention the access 
control means includes means for allowing 70 
conditional access, e.g. read only access, to 
the store. 

As will be appreciated, said main store and 
said table and further stores may be consti- 
tuted by storage distributed about the sys- 75 
tern. For example, normally each processor 
will itself contain registers or other forms of 
storage which may constitute part of said 
main store and/or part of said table and/or 
further stores. 80 

In a practical example A ==4 bits, B=12 
bits, X = 16 bits, Y = 20 bits and Z=8 bits. 

Preferably all of said stores and said 
processors are interconnected by a data-bus 
or highway and, as known per se a central 85 
control unit is provided to determine which 
one of said processors is given access to said 
data- bus at any one time. 

Preferably said table store and, where 
provided, said further store, is accessible for 90 
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changing any of the contents thereof to one 
and one only executive processor. Said last 
mentioned processor may be one of said 
plurality of processors or an additional proc- 
5 essor. 

Each table stored in said table store may 
relate to data required by an individual one 
of said processors or to data required by each 
of a plurality of said processors. 

10 In operation, some or all of said tables 
relating to data frequently required may be 
regarded as permanent or resident. 

A particular embodiment of the invention 
will now be described by way of example 

15 with reference to Figures 1 and 2 of the 
accompanying drawings which are highly 
schematic block diagrams representing two 
examples of a data processing system in 
accordance with the present invention, and 

20 also in accordance with the invention 
claimed in our co-pending Application 
43908/77. Serial No. 1601955. In both Fig- 
ures like references are used for like parts. 
Referring to Figure 1, twelve processors 

25 reference 1 to 12 are connected to a data-bus 
13. Also connected to the data-bus 13 is a 
main store 14, table allocating means consti- 
tuted by a table store 15, a control unit 16 
and an executive processor 17, which consti- 

30 tutes means for changing the table allocating 
means. 

The data-bus 13 is controlled by control 
unit 16 so as to be capable of passing the 
following signals: — 
35 (a) Signals from the processors 1 to 12 
showing which of these currently awaiting 
use of the data-bus 13. 

(b) Signals from the data-bus control unit 16 
indicating which one of the processors 1 to 12 

40 is to make use of the data-bus when this 
becomes free. 

(c) A digital codeword generated by one of 
the processors 1 to 12 and defining the data 
item to which access is required by that 

45 processor. 

(d) A signal defining the nature of the access 
required, e.g. "read" or "write" and 

(e) Signals defining the content of the data 
item to which access is required, these last 

50 mentioned signals being generated by the 
digital processor currently making use of the 
data-bus for *write" operations and being 
signals generated by the main store 14 or the 
table store 15 or that one of the digital 

55 processors 1 to 12 providing the data for 
"read" operations. 

As known per se the data-bus 13 is also 
provided to cany other types of information 
such as signals indicating when particular 

60 data items are available on the data-bus or 
when the transfer of particular sets of infor- 
mation is complete or signals relating to the 
functions of the executive processor 17. 
Table store 15 contains twelve tables each 

65 individual to a different one of the processors 



1 to 12. Each stored table contains a set of 
addressing codewords relating to different 
regions of the main store 14. Each of the 
regions of the main store 14 contains a 
plurality of data storage areas for individual 70 
data items, which may be required by one or 
more of the processors I to 12, at different 
times. 

Each digital processor 1 to 12 is capable of 
generating a sixteen bit address output. The 75 
main store 14 is provided to store of the order 
of 1,000,000 individual data items at corre- 
sponding locations and is capable of being 
addressed by a 20 bit addressing codeword. 

The connection of the table store to the 80 
data-bus 13 is such that as the control unit 16 
provide access to the data-bus 13 for a 
particular one of the processors 1 to 12 so, by 
means of the connection represented at 18 
(which constitutes table selecting means) that 85 
table in the table store 15 is selected which is 
appropriate to the particular one of the 
processors 1 to 12. The addressing 16 bit 
codeword generated by the particular one of 
processors 1 to 12 is divided into two parts, 90 
the first of which consists of the four most 
significant digits and the second of which 
consists of the remaining twelve least signifi- 
cant digits. The four most significant digits 
are applied to the table store 15 via the 95 
connection represented at 19 (which consti- 
tutes means for addressing the selected table) 
to address the selected relevant stored table 
which thereupon outputs an eight bit co- 
deword which is applied via connection 20 100 
(which constitutes access control means) to 
the main store 14 to select the region therein 
which is of interest The least significant 
twelve digits of the addressing codeword 
generated by the selected one of the proces- 105 
sors 1 to 12 is applied via data transfer means 
(constituted by the data-bus and connection 
21) to the main store 14 where it is utilised to 
address the particular region identified in the 
main store 14 and thus select the data item at 1 10 
that time required by the processor. This is 
transmitted to the processor via connection 
22 and the data-bus 13. 

Thus whilst the digital processors are 
capable of generating sixteen bit addressing 115 
codewords only, the effective codeword util- 
ised to address the main store is twenty bits 
in length and thus the total storage capability 
of the system is relatively increased. It will be 
noted that a particular codeword generated 120 
by one of the processors 1 to 12 may define 
the. same address in the main store 14 as the 
identical codeword generated by another of 
the processors 1 to 12 or it may identify a 
totally different address as determined by the 125 
content of the relevant table in the table store 
15. 

Whilst in this example a separate executive 
processor 17 is provided to have exclusive 
control of the varying or changing of the 130 
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tables stored in table store 15, one of the 
processors 1 to 12 may be designed as an 
executive processor. 
In addition to the twelve tables referred to 
5 above, table store 15 also includes storage 
further defining the permitted nature and 
extent of the access to the various data items 
stored in the main store 14. As well as one of 
the aforementioned addressing codewords 

10 being transmitted to address the main store 
14, a codeword is also signalled from tabic 
store 15 to the main store 14 in order to 
constrain the response to the addressing of 
the main store 14 and thus limit the effects of 

15 errors in programs. 

Referring to Figure 2, again twelve proces- 
sors reference 1 to 12 are connected to a data- 
bus 13. Also connected to the data-bus 13 is a 
main store 14, a table store 15, a control unit 

20 16 and a further or "table number" store 23. 
Within table store 15 are stored sixty-four 
tables relating to data which will be required 
by the processors 1 to 12. The table store 15 is 
provided to be addressed via the connection 

25 24 (in this case separate from the data-bus 13 
in the interest of speed) by table number 
store 23. In table number store 23 is stored 
twelve table numbers each identifying a table 
within table store 15 which is to be selected 

30 when a particular one of the processors 1 to 
12 wishing to access the main store 14 is 
selected. The digital number received from 
the table number store 23 by the table store 
1 5 to select the appropriate table therein is in 

35 six bit form. The addressing of the selected 
table in table store 15 by the most significant 
four digits of the addressing codeword gener- 
ated by the selected processor and the 
addressing of the selected region of the main 

40 store 14 by the least significant twelve digits 
is as described with reference to Figure 1. 

In effect, in both Figures 1 and 2, the 
tables stored in table store 15 may be 
considered to provide a plurality of sets of 

45 access routes to the different regions of the 
main store 14, a given set being selected in 
dependence upon the data required by a 
particular processor, in the case of Figure 2, 
as identified by the table number entered 

50 into further "table number" store 23. 

It will be noted that different processors 
may at different times access the same table 
stored in table store 15 and indeed, if the 
number of different tables required is greater 

55 than can be provided in the table store 15, 
only those tables which are common to more 
than one of the processors 1 to 12 or which 
are most commonly in use by one or other of 
the processors may be stored in the table 

60 store 15 in a permanent or resident fashion. 
Tables relating to less frequently required 
sets of data items may be replaced in the 
table store 1 5 as required. 

In addition to the twelve tables referred to 

65 in connection with Figure 1 and the sixty- 



four tables referred to in connection with 
Figure 2, table store 15 also includes storage 
further defining the permitted nature and 
extent of the access to the various data items 
stored in the main store 14. As well as one of 70 
the aforementioned addressing codewords 
being transmitted to address the main store 
14, a codeword is also signalled from table 
store 15 to the main store 14 in order to 
constrain the response to the addressing of. 75 
the main store 14 and thus limit the effects of 
errors in programs. 

WHAT WE CLAIM IS:— 

1 . A multi-processor data processing sys- 80 
tem comprising: a store having a plurality of 
locations each defined by an address; a 
plurality of processors each having a multi- 
bit address output and means for feeding at 
least some bits of this output to the store to 85 
provide a corresponding number of bits of an 
address input of the latter; data transfer 
means connected between the processors and 
the store for the communication of data 
between a processor and an address in the 90 
store which address is dependent on the 
address output of the processor, access con- 
trol means for controlling access to the store 

by the processors in response to receipt of a 
code; a plurality of tables each containing 95 
codes; table selecting means for transmitting 
a processor identity signal indicating what 
processor is currently to access the store and 
for selecting a table associated with that 
processor, means for addressing the selected 100 
table with at least part of the address output 
of that processor which is currently to access 
the store whereby the table outputs a code; 
and means for feeding the code outputted by 
the selected table to the access control means 105 
thereby causing said access control means to 
control access to the store in a manner 
defined by said code. 

2. A multi-processor data processing sys- 
tem in accordance with claim 1 wherein: said 110 
multi-bit address output of each processor 
has A + B digits and means is provided for 
feeding the B digits to the store to provide a 
corresponding B digits of said address input 

of the store; said means for addressing a 115 
selected table is adapted to define a table 
address in dependence on said A digits of 
said multi-bit address output of each proces- 
sor, each code contained in the tables has Z 
digits; and said access control means is 120 
provided by a further Z digits of said address 
input of the store and by a connection for 
feeding the Z digits of the codes outputted by 
the tables to the corresponding Z digits of the 
store address whereby said codes limit access 125 
of the processors to particular locations in the 
store. 

3. A multi-processor data processing 
system in accordance with claim 1 or 2 
wherein said access control means includes 130 
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means for allowing conditional access, e.g. 
read only access, to the main store. 

4. A mu lti- processor data processing sys- 
tem in accordance with any preceding claim 

5 wherein: each processor has an output on 
which it produces a processor identification 
signal identifying itself as being a processor 
which requires access to the store and said 
table selecting means includes table allocat- 

10 ing means connected to receive the processor 
identification signal and to select a table 
which it associates with the processor identi- 
fied as requiring access. 

5. A multi-processor data processing sys- 
15 tern in accordance with claim 4 wherein there 

are more tables than processors. 

6. A multi-processor data processing sys- 
tem in accordance with claim 5 including 
means for changing the table allocating 

20 means so that it associates different tables 
with different processors. 

ROGER K. TOLFREE, 
Chartered Patent Agent, 
Marconi House, 
New Street, 
Chelmsford, 
Essex. 

Agent for the Applicant. 
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